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System and Method for Fault Tolerant Stream Splitting 

BACKGROUND OF THE INVENTION 
Field of the Invention 

This invention relates generally to the field of network services. More 
particularly, the invention relates to an improved architecture for providing fault 
tolerant data communication. 

Description of the Related Art 

As is known in the art, streaming is a mechanism for playing back audio 
and/ or video content over a network in real-time, typically used in situations 
where network bandwidth is limited. The basic streaming concept is that the 
destination (e.g., a client) begins to play back the underlying streaming file from 
a buffer before the entire file has been received from its source. 

A traditional network streaming system is illustrated in Figure 1. As 
shown, one or more clients 150, 160, configured with streaming application 
software such as RealPlayer ® from RealNetworks® or Windows Media® Player 
from Microsoft® Corporation, communicate with one or more streaming servers 
110, 111, . . . N, over a network 100 (e.g., the Internet). The group of streaming 
servers 110, 111, . . . N, are located together at a point of presence ("POP") site. 
Each of the streaming servers 110, 111, . . . N, may store a copy of the same 
streaming data or, alternatively, may store different streaming data, depending 
on the configuration at the POP site 130. 
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In operation, when a client 150 requests a particular streaming file from a 
server at the POP site 120, the request is received by a load balancer module 120, 
which routes the request to an appropriate streaming server 111. Which server is 
"appropriate" may depend on where the requested file is stored, the load on 
each server 110, 111, . . . N, and/or the type of streaming file requested by the 
client (e.g., Windows Media format or RealPlayer format). Once the file has been 
identified by the load balancer 120 on an appropriate server - server 111 in the 
illustrated example - it is streamed to the requesting client 150 (represented by 
stream 140) through the network 100. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

A better understanding of the present invention can be obtained from the 
following detailed description in conjunction with the following drawings, in 
which: 

5 FIG. 1 illustrates a prior art system and method for streaming content 

over a network. 

FIG, 2 illustrates an exemplary network architecture including elements of 
the invention. 

FIG. 3 illustrates an exemplary computer architecture including elements 
1 0 of the invention. 

FIG. 4 illustrates various streaming sources supported by one 
embodiment of the invention. 

FIG. 5 illustrates stream splitting implemented in on embodiment of the 
invention. 

15 FIG. 6 illustrates a system for implementing a backup root splitter 

according to one embodiment of the invention. 

FIG. 7 illustrates a method for implementing a backup root splitter 
according to one embodiment of the invention. 
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DETAILED DESCRIPTION 

In the following description, for the purposes of explanation, numerous 
specific details are set forth in order to provide a thorough understanding of the 
present invention. It will be apparent, however, to one skilled in the art that the 
5 present invention may be practiced without some of these specific details. In 
other instances, well-known structures and devices are shown in block diagram 
form to avoid obscuring the underlying principles of the invention. 

An Exemplary Network Architecture 
Elements of the present invention may be included within a multi-tiered 
10 networking architecture 200 such as that illustrated in Figure 2, which includes 
one or more data centers 220-222, a plurality of "intermediate" Point of Presence 
("POP") nodes 230-234 (also referred to herein as "Private Network Access 
Points," or "P-NAPs"), and a plurality of "edge" POP nodes 240-245 (also 
referred to herein as "Internet Service Provider Co-Location" sites or "ISP Co- 
15 Lo" sites). 

According to the embodiment depicted in Figure 2, each of the data 
centers 220-222, intermediate POPs 230-234 and/or edge POPs 240-245 are 
comprised of groups of network servers on which various types of network 
content may be stored and transmitted to end users 250, including, for example, 
20 Web pages, network news data, e-mail data, File Transfer Protocol ("FTP") files, 
and live & on-demand multimedia streaming files. It should be noted, however, 
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that the underlying principles of the invention may be practiced using a variety 
of different types of network content. 

The servers located at the data centers 220-222 and POPs 230-234; 240-245 
may communicate with one another and with end users 150 using a variety of 
5 communication channels, including, for example, Digital Signal ("DS") channels 
(e.g., DS-3/T-3, DS-1/T1), Synchronous Optical Network ("SONET") channels 
(e.g., OC-3/STS-3), Integrated Services Digital Network ("ISDN") channels, 
Digital Subscriber Line ("DSL") channels, cable modem channels and a variety of 
wireless communication channels including satellite broadcast and cellular. 

10 In addition, various networking protocols may be used to implement 

aspects of the system including, for example, the Asynchronous Transfer Mode 
("ATM"), Ethernet, and Token Ring (at the data-link level); as well as 
Transmission Control Protocol/Internet Protocol ("TCP/IP"), Internetwork 
Packet Exchange ("IPX"), AppleTalk and DECnet (at the network/transport 

15 level). It should be noted, however, that the principles of the invention are not 
limited to any particular communication channel or protocol. 

In one embodiment, a database for storing information relating to 
distributed network content is maintained on servers at the data centers 220-222 
(and possibly also at the POP nodes 230-234; 240-245). This information may 
20 include the different POP sites which currently contain a copy of network 
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content. The database in one embodiment is a distributed database (i.e., spread 
across multiple servers) and may run an instance of a Relational Database 
Management System (RDBMS), such as Microsoft™ SQL-Server, Oracle™ or the 
like. 

An Exemplary Computer Architecture 
Having briefly described an exemplary network architecture which 
employs various elements of the present invention, a computer system 300 
representing exemplary clients and servers for implementing elements of the 
present invention will now be described with reference to Figure 3. 

One embodiment of computer system 300 comprises a system bus 320 for 
communicating information, and a processor 310 coupled to bus 320 for 
processing information. The computer system 300 further comprises a random 
access memory (RAM) or other dynamic storage device 325 (referred to herein as 
"main memory"), coupled to bus 320 for storing information and instructions to 
be executed by processor 310. Main memory 325 also may be used for storing 
temporary variables or other intermediate information during execution of 
instructions by processor 310. Computer system 300 also may include a read 
only memory ("ROM") and/or other static storage device 326 coupled to bus 320 
for storing static information and instructions used by processor 310. 
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A data storage device 327 such as a magnetic disk or optical disc and its 
corresponding drive may also be coupled to computer system 300 for storing 
information and instructions. The computer system 300 can also be coupled to a 
second 1/ O bus 350 via an I/O interface 330. A plurality of I/O devices may be 
coupled to 1/ O bus 350, including a display device 343, and/or an input device 
(e.g., an alphanumeric input device 342 and/or a cursor control device 341). 

The communication device 340 is used for accessing other computers 
(servers or clients) via a network 100. The communication device 340 may 
comprise a modem, a network interface card, or other well known interface 
device, such as those used for coupling to Ethernet, token ring, or other types of 
computer networks. 

Embodiments of the Invention 
Stream Splitting 

Embodiments of a system configured to stream live and on-demand 
audio /video content will now be described with respect to Figures 4 and 5. As 
shown in Figure 4, one embodiment receives and processes incoming 
audio/video content from a variety of sources including, but not limited to, live 
or recorded signals 401 broadcast over satellite links 410; live signals 402 
provided via video conferencing systems 411; and/or live or recorded signals 
403 transmitted over dedicated Internet Protocol ('TP") links 412. It should be 
noted, however, that a various other network protocols (i.e., other than IP) may 
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be employed while still complying with the underlying principles of the 
invention. In one embodiment, each of the modules illustrated in Figure 4 reside 
at a data center 220. 

System acquisition and management modules ("SAMs") 420 open and 
close communication sessions between the various sources 401-403 as required. 
For example, when a content provider wants to establish a new live streaming 
session, the SAM 420 will open a new connection to handle the incoming 
audio/video data (e.g., after determining that the content provider has the right 
to establish the connection). 

The SAM module 420 will handle incoming signals differently based on 
whether the signals have already been encoded (e.g., by the content providers) 
and/ or based on whether the signals are comprised of "live" or "on demand" 
content. For example, if a signal has not already been encoded by a content 
provider (e.g., the signal may be received at the data center 220 in an analog 
format or in a non-streaming digital format), the SAM module 420 will direct the 
signal to one or more streaming encoder modules 1430, which will encode the 
stream in a specified digital streaming format (e.g., Windows Media®) format, 
Real G2™ format,... etc). 

If the incoming signal is live, the streaming encoders 430 transmit the 
encoded signal directly to one or more streaming origin servers 510 (which 
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distribute the signal to various POP nodes as described below) and/ or to one or 
more content storage devices 431 at the data center 220. If, however, the 
incoming signal is an on-demand signal (i.e., to be stored and viewed by clients 
at any time), then the streaming encoders 430 transmit the encoded signal 
5 directly to the content storage devices 431. Similarly, if the incoming signal is 
already encoded in a particular streaming format, it may be transmitted directly 
to the content storage devices 431. 

As new audio/video streaming content is added to the content storage 
devices 431, the SAM module 420 causes a storage database 430 to be updated 
10 accordingly (e.g., via a content delivery subsystem). The storage database 430 in 
one embodiment is a distributed database which tracks all network content as it 
distributed and stored at various POP sites throughout the network. 

As illustrated in Figure 5, the encoded signal is transmitted from the 
streaming origin servers 510 to streaming splitters 520-522, 530-532 located at a 

15 various I-POP nodes 230-232 and E-POP nodes 240-242. Employing streaming 
splitters as illustrated conserves a substantial amount of network bandwidth. 
For example, in the illustrated embodiment each streaming splitter 520-522, 530- 
532 receives only a single stream of live audio/video content from an upstream 
server, which it then divides into several independent streams. This 

20 configuration is particularly useful for streaming configurations which do not 
support multicasting. 



TCW 



10 



42390.P8795 



Moreover, employing streaming splitters within a multi-tiered hierarchy, 
as illustrated in Figure 5, reduces bandwidth at each level in the hierarchy. For 
example, a single stream from a live streaming event may be transmitted from a 
streaming origin server 510 to an I-POP streaming splitter 521. The streaming 
5 splitter 521 may then transmit a single stream to each of the E-POP streaming 
splitters 530-532, which may then transmit the live event to a plurality of end 
users 540-548. Accordingly, the network path between the data center 220 and 
the I-POP 231 is loaded with only a single stream and each of the three network 
paths between the I-POP 231 and the E-POPs 240-242 are loaded with only a 
10 single stream. The incoming streams are then split at each of the E-POPs 240-242 
to provide the live event to a plurality of end users 540-548. 

Fault Tolerant Stream Splitting 
As illustrated in Figure 6, one embodiment of the invention includes one 
or more root splitters 630 configured at POP sites 620 to receive a stream from an 
15 origin server and distribute the stream to a plurality of leaf splitters 631-635. 
Each of the leaf splitters 631-635 serve a plurality of end users 650 by further 
splitting each stream received from the root splitter 630 into another plurality of 
end-user streams. 

It can be seen from Figure 6 that, for a particular live or scheduled 
20 streaming event, the streaming encoder 530, the origin servers 510 and the root 
splitter 630 all represent single points of failure. In one embodiment, potential 
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failures at the data center 200 components (i.e., the origin server 510 and 
streaming encoder 530) are handled through allocation of redundant 
encoder/ origin server pair combinations for each live/scheduled event. 
However, in some circumstances, this level of redundancy may be impractical at 
various POP sites 620 (e.g., due to limited media server resources at the site, 
limited and costly rack space, . . . etc). As such, in one embodiment, a more 
efficient mechanism may be implemented to provide fault tolerance at these POP 
sites 620. 

As illustrated in Figure 6, in one embodiment, one or more of the leaf 
splitters (e.g., leaf splitter 631) are configured as backups to the primary root 
splitter 630. In this embodiment, the health of the root splitter is continually 
monitored by a monitoring subsystem which may reside on the load balancer 
module 625, the redirection subsystem 625, or as a separate monitoring module 
and the data center and/or the POP site 620. 

In one embodiment, the root splitter 630 is configured to provide an 
update to the monitoring subsystem at predetermined intervals. This may be 
accomplished by an agent 640 continually running on the root splitter 630and 
configured to communicate with the monitoring subsystem. The periodic update 
in this embodiment acts as a "heartbeat" which indicates to the monitoring 
subsystem that the root splitter is operating within normal parameters. If the 
monitoring subsystem does not receive an update for one or more periods, it 
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may determine that the root splitter has become inoperative and assign the 
backup root splitter 631 as the new primary root splitter. In one embodiment, 
the agent 641 running on the backup root splitter 631 performs the 
reconfiguration process. Alternatively, or in addition, the monitoring subsystem 
may actively poll the agent 640 running on the root splitter 630 to verify that the 
root splitter 630 is operating reliably. 

The operation of one embodiment of the system illustrated in Figure 6 will 
now be described with respect to the flowchart in Figure 7. At 710, a user 
attempts to view a particular live or scheduled streaming event (e.g., such as a 
Webcast). The user's request is received and processed by the redirection 
subsystem 610, which (at 715) directs the user to a particular POP site 620 from 
which the stream will be delivered (e.g., by returning a path directing the user's 
streaming application that POP site 620). 

At 720, a load balancer module 625 residing at the POP site 620 selects a 
particular leaf splitter (e.g., splitter 633) from a group of leaf splitters 631-635 at 
the site. In one embodiment, the load balancer 625 is a layer 4 switch which 
continually monitors the load on each of the leaf splitters 631-635, and assigns 
the new user request to the least-loaded splitter. In this embodiment, the layer 4 
switch may be identified by a virtual internet protocol ("VIP") address included 
in the path sent by the redirection subsystem 610. 
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At 725, a root splitter failure is detected by the monitoring subsystem (e.g., 
via one or more of the failure detection techniques described above). As a result, 
the monitoring subsystem directs the backup root splitter 631 (e.g., via the 
backup agent 641) to reconfigure itself as the new primary root splitter 630. In 
5 addition, the monitoring subsystem and/or the backup agent 641 directs the load 
balancer 625 to remove the backup root splitter 631 from the group of leaf 
splitters 631-635 monitored by the load balancer module 625. 

It should be noted that the new primary root splitter 631, load balancer 
625, leaf splitters 632-625, and/ or redirection subsystem 610 may be reconfigured 

10 differently following a root splitter 630 failure depending on the streaming 
formats supported by the system. When a user requests a file encoded in a 
RealPlayer® streaming format (e.g., through a RealPlayer application residing on 
the client computer) the redirection subsystem transmits a comprehensive path 
to the user, specifying the location of the streaming file and the servers through 

15 which the data stream will pass on its way to the user. For example, a path such 
as "rtsp:\\<VIP> \Split\<Root Server IP>\Split\ <Origin Server IP>\<Encoder 
IP> \live_stream.rm" may be passed to the client's streaming application, 
identifying the virtual IP address of the load balancer 625, the root splitter 630, 
the origin server 510, and the encoder 530 as well as the name of the actual 

20 streaming file ("live_stream.rm"). Accordingly, when the backup root server 631 
is reconfigured as the primary root server 630 as described above, the path 
subsequently transmitted to users by the redirection subsystem 610 is updated to 
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reflect the new IP address of the root splitter in the <Root Server IP> field (i.e., 
the IP address of the former backup server 631). 

By contrast, if the system is configured to support the Windows Media 
Technologies ("WMT") streaming format, each server within the streaming path 
may need to be updated following a root splitter 630 crash. More particularly, in 
this embodiment, WMT server "publishing points" are reconfigured beforehand 
on each server to point back to the upstream splitter 630, origin server 510, 
and/or encoder 530. 

For example, following a user request for streaming content an exemplary 
URL returned by the Redirection Subsystem 610 may look something like: 
"mms:/ /<VIP>/ <Broadcast Publishing Point(3)>." Each edge splitter behind 
the VIP address would then expose "Broadcast Publishing Point(3)" and would 
thereby be configured to reference, for example, "<Root Splitter IP>/<Broadcast 
Publishing Point(2)>." Continuing with this example, the WMT root splitter 630, 
in turn, would expose "Broadcast Publishing Point(2)" which would be pre- 
configured to reference "<Origin Server IP>/<Broadcast Publishing Point(l)>." 
Finally, "Broadcast Publishing Point(l)," exposed by the WMT origin server 510 
in one embodiment, would be filled with the stream received from the streaming 
encoder 530. 
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Thus, in this embodiment, when the monitoring subsystem detects a 
failure in the primary WMT root splitter 630, it must not only reconfigure the 
load balancer 625 to remove the backup root splitter 631 from the leaf splitter 
group, it must also reconfigure all the "Broadcast Publishing Point(3)" on the 
5 remaining leaf splitters 632-635 so that they reference the new root splitter 631. 
In addition, the new root splitter 631 must be reconfigured to remove its 
"Broadcast Publishing Point(3) // and now expose "Broadcast Publishing 
Point(2)/ / which points back to the origin server's 510's publishing point. 

Accordingly, in can be seen that one of the benefits of the foregoing 
10 configuration is that the Redirection Subsystem 610 can offer up the same URL to 
the user, even after the primary root splitter 630 fails. The user will then be 
provided the same stream using a newly-configured set of publishing points. 

Regardless of which streaming format is used, new streams are provided 
to users through the new primary root splitter at 735. At 740, the operations staff 
15 at the data center is notified of the primary root server failure. The operations 
staff may then attempt to evaluate and solve the problem remotely before 
making a trip to the POP site 620. 

Embodiments of the present invention include various steps, which have 
been described above. The steps may be embodied in machine-executable 
20 instructions. The instructions can be used to cause a general-purpose or special- 
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purpose processor to perform certain steps. Alternatively, these steps may be 
performed by specific hardware components that contain hardwired logic for 
performing the steps, or by any combination of programmed computer 
components and custom hardware components. 

Elements of the invention may also be provided as a machine-readable 
medium for storing the machine-executable instructions. The machine-readable 
medium may include, but is not limited to, floppy diskettes, optical disks, CD- 
ROMs, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, magnet 
or optical cards, propagation media or other type of media /machine-readable 
medium suitable for storing electronic instructions. For example, the present 
invention may be downloaded as a computer program which may be transferred 
from a remote computer (e.g., a server) to a requesting computer (e.g., a client) 
by way of data signals embodied in a carrier wave or other propagation medium 
via a communication link (e.g., a modem or network connection). 

Throughout the foregoing description, for the purposes of explanation, 
numerous specific details were set forth in order to provide a thorough 
understanding of the invention. It will be apparent, however, to one skilled in 
the art that the invention may be practiced without some of these specific details. 
For example, although the foregoing embodiments were described in the context 
of specific streaming formats (e.g., Windows Media and RealMedia), various 
other streaming media formats may be implemented consistent with the 
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underlying principles of the invention. Accordingly, the scope and spirit of the 
invention should be judged in terms of the claims which follow. 
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CLAIMS 



What is claimed is: 



1 1. A system comprising: 

2 a primary root splitter to split a data stream transmitted from an upstream 

3 server into a plurality of leaf splitter streams; 

4 a plurality of leaf splitters to split each of said leaf splitter streams into a 

5 plurality of end user streams, wherein one or more of said plurality of leaf 

6 splitters is a backup root splitter; and 

7 root splitter reassignment logic to reassign one of said backup root 

8 splitters as a new primary root splitter responsive to detecting a problem with 

9 said primary root splitter. 
1 

1 2. The system as in claim 1 further comprising a load balancer module to 

2 direct client streaming requests to particular leaf splitters based on relative load 

3 on said leaf splitters. 
1 

1 3. The system as in claim 1 further comprising a redirection subsystem 

2 to redirect client streaming requests to a particular point of presence site. 
1 

l 4. The system as in claim 2 further comprising load balancer update 



2 logic for removing said backup leaf splitter from said plurality of leaf splitters to 

3 which said load balancer directs user streaming requests responsive to said 

4 backup root splitter being reassigned as a primary root splitter. 
1 

1 5. The system as in claim 3 further comprising redirection subsystem 

2 update logic for notifying said redirection subsystem of said new primary root 
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3 splitter responsive to said backup splitter being reassigned as said new primary 

4 root splitter. 
1 

1 6. The system as in claim 5 wherein said redirection subsystem update 

2 logic transmits said new primary root splitter's IP address to said redirection 

3 subsystem. 
1 

1 7. The system as in claim 1 further comprising publish point update 

2 logic for updating publishing points within said system responsive to said 

3 backup root server being reassigned as said primary root server. 
1 

1 8. The system as in claim 1 further comprising monitoring logic for 

2 monitoring said primary root splitter to determine whether said root splitter is 

3 operating within normal parameters, 
l 

l 9. The system as in claim 8 wherein said monitoring logic receives a 



2 periodic heartbeat signal from said primary root splitter, and wherein not 

3 receiving said periodic heartbeat signal for one or more periods indicates a 

4 problem with said primary root splitter. 
1 

1 10. The system as in claim 8 wherein said monitoring logic transmits a 

2 monitor signal to said primary root splitter, and wherein not receiving a 

3 response from said root splitter indicates a problem with said primary root 

4 splitter, 
l 
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1 11. A method comprising: 

2 monitoring a primary root splitter to ensure that said primary root splitter 

3 is operating within predefined parameters, said primary root splitter to split a 

4 single data stream into multiple data streams transmitted to multiple leaf 

5 splitters; and 

6 reassigning one of said leaf splitters as a new primary root splitter 

7 responsive to detecting that said primary root splitter is not operating within 

8 said predefined parameters. 
1 

1 12. The method of claim 11 further comprising: 

2 updating a load balancer module to indicate that said leaf splitter is 



3 reassigned as a primary root splitter, said load balancer module for distributing 

4 user streaming requests to one or more of said leaf splitters based on load on 

5 each of said leaf splitters, 
l 



1 13. The method as in claim 11 further comprising: 

2 updating a redirection subsystem to indicate that said leaf splitter is 

3 reassigned as a primary root splitter, said redirection subsystem for directing 

4 client streaming requests to a particular point of presence site, 
l 

1 14. The method of claim 13 further comprising: 

2 updating a load balancer module at said point of presence site to indicate 

3 that said leaf splitter is reassigned as a new primary root splitter, said load 

4 balancer module for distributing user streaming requests to one or more of said 

5 leaf splitters at said point of presence site based on load on each of said leaf 

6 splitters, 
l 
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1 15. The method as in claim 13 wherein updating said redirection 

2 subsystem comprises transmitting said new primary root splitter's IP address to 

3 said redirection subsystem. 
1 

1 16. The method as in claim 11 further comprising: 

2 updating one or more broadcast publish points to indicate said new 

3 primary root splitter. 
1 

1 17. A system comprising: 

2 a monitoring subsystem to detect whether a primary root splitter is 

3 operating under predetermined operational parameters; and 

4 root splitter reassignment logic to reassign a backup root splitter as a new 

5 primary root splitter responsive to detecting that said primary root splitter is 

6 operating outside of said predetermined operational parameters, 
l 

l 18. The system as in claim 17 wherein said backup root splitter is also a 



2 leaf splitter to receive a data stream from said primary root splitter and to split 

3 said data stream into a plurality of user streams when said primary root splitter 

4 is operating under said predetermined operational parameters, 
l 

1 19. The system as in claim 17 wherein said monitoring subsystem detects 

2 whether said primary root splitter is operating under predetermined operational 

3 parameters by periodically receiving a signal transmitted from said primary root 

4 splitter, 
l 
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20. The system as in claim 17 further comprising load balancer logic for 
directing client streaming requests to said leaf splitter based on relative load of 
said leaf splitter in relation to one or more additional leaf splitters. 

21. The system as in claim 20 further comprising a redirection subsystem 
to redirect client streaming requests to a particular point of presence site at 
which said load balancer and one or more of said leaf splitters reside. 

22. An article of manufacture including a sequence of instructions which, 
when executed by a processor, cause said processor to: 

monitor a primary root splitter to ensure that said primary root splitter is 
operating within predefined parameters, said primary root splitter to split a 
single data stream into multiple data streams transmitted to multiple leaf 
splitters; and 

reassign one of said leaf splitters as a new primary root splitter responsive 
to detecting that said primary root splitter is not operating within said 
predefined parameters. 

23. The article of manufacture as in claim 22 including additional 
instructions which, when executed by said processor, cause said processor to: 

update a load balancer module to indicate that said leaf splitter is 
reassigned as a primary root splitter, said load balancer module for distributing 
user streaming requests to one or more of said leaf splitters based on load on 
each of said leaf splitters. 
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1 24. The article of manufacture as in claim 23 including additional 

2 instructions which, when executed by said processor, cause said processor to: 

3 update a redirection subsystem to indicate that said leaf splitter is 

4 reassigned as a primary root splitter, said redirection subsystem for directing 

5 client streaming requests to a particular point of presence site, 
l 

1 
l 
1 
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ABSTRACT 

A system is described comprising: a primary root splitter to split a data 
stream transmitted from an upstream server into a plurality of leaf splitter 
streams; a plurality of leaf splitters to split each of the leaf splitter streams into a 
plurality of end user streams, wherein one or more of the plurality of leaf 
splitters is a backup root splitter; and root splitter reassignment logic for 
reassigning one of the backup root splitters as a new primary root splitter 
responsive to detecting a problem with the primary root splitter. 

Also described is a method comprising: monitoring a primary root splitter 
to ensure that the primary root splitter is operating within predefined 
parameters, the primary root splitter to split a single data stream into multiple 
data streams transmitted to multiple leaf splitters; and reassigning one of the leaf 
splitters as a new primary root splitter responsive to detecting that the primary 
root splitter is not operating within the predefined parameters. 
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DECLARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION 
(FOR INTEL CORPORATION PATENT APPLICATIONS) 

As a below named inventor, ! hereby declare thai: 

My residence, post office address and citizenship are as stated below, next to my name. 

I believe I am the original, first, and sole Inventor (if only one name is listed below) or an original, 
first, and joint inventor (if plural names are listed below) of the suhject matter which is claimed and 
for which a patent is sought on the invention entitled: 

System And Method For Fault Tolerant Stream Splitting 

the specification of which 

X is attached hereto, 

was filed on as 

United States Application Number , 

or PCT International Application Number 

and was amended on , 

(if applicable) 

1 hereby state that 1 have reviewed and understand the contents of the above-identified 
specification, including the c!aim(s), as amended by any amendment referred to above. 1 do not 
know and do not believe that the claimed invention was ever known or used in the United States of 
America before my invention thereof, or patented or described in any printed publication in any 
country before my invention thereof or more than one year prior to this application, that the same 
was not in public use or on sale in the United States of America more than one year prior to this 
application, and that the invention has not been patented or made the subject of an inventor's 
certificate Issued before the date of this application in any country foreign to the United States of 
America on an application filed by me or my legal representatives or assigns more than twelve 
months (for a utility patent application) or six months (for a design patent application) prior to this 
application. 

1 acknowledge the duty to disclose all information known to me to be material to patentability as 
defined in Title 37, Code of Federal Regulations, Section 1 .56. 

I hereby claim foreign priority benefits under Title 35, United States Code, Section 119(a)-(d), of any 
foreign application(s) for patent or inventor's certificate listed below and have also identified below 
any foreign application for patent or inventors certificate having a filing date before that of the 
application on which priority is claimed: 
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Prior Foreign Application^ 



Priority 
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(Number) 



(Country) 



{Day/Month/Year Filed) Yes No 



(Number) 



(Country) 



(Day/Month/Year Filed) Yes No 



(Number) 



(Country) 



(Day/Month/Year Filed) Yes No 



I hereby claim the benefit under Title 35 5 United States Code, Section 1 1 9(e) of any United States 
provisional application(s) listed below: 



Application Number 



Filing Date 



Application Number 



Filing Date 



I hereby claim the benefit under Title 35, United States Code, Section 120 of any United States 
application (s) listed below and T insofar as the subject matter of each of the claims of this application 
is not disclosed in the prior United States application in the manner provided by the first paragraph 
of Title 35, United States Code, Section 1 12, 1 acknowledge the duty to disclose all information 
known to me to be material to patentability as defined in Title 37, Code of Federal Regulations, 
Section 1.56 which became available between the filing date of the prior application and the national 
or PCT international filing date of this application: 
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1 hereby appoint the persons Fisted on Appendix A hereto (which is incorporated by reference and a 
part of this document) as my respective patent attorneys and patent agents, with full power of 
substitution and revocation, to prosecute this application and to transact all business in the Patent 
and Trademark Office connected herewith. 



Send correspondence to Thomas C, Webster BLAKELY, SOKOLOFF, TAYLOR & 

(Name of Attorney or Agent) 
ZAFMAN LLP, 12400 Witehire Boulevard 7th Floor, Los Angeles, California 90025 and direct 

telephone calls to Thomas C» Webster 3 (408) 720-8300. 

(Name of Attorney or Agent) 

I hereby declare that all statements made herein of my own knowledge are true and that all 
statements made on information and belief are believed to be true; and further that these 
statements were made with the knowledge that willful false statements and the like so made 
are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United 
States Code and that such willful false statements may jeopardize the validity of the 
application or any patent Issued thereon. 
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Residence Beaverton, Oregon m Citizenship USA 

(City, State) (Country) 

Post Office Address 9895 S. W. Stonecreek Drive 

Beaverton, Oregon 97001 



Full Name of Second/Joint Inventor 



Inventor 1 © Signature Date . 

Residence Citizenship . 



{City, State) (Country) 
Post Office Address 
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APPENDIX A 



William E. Afford Reg. No. 37,764; Farzad E. Amini, Reg. No, P42,261 ; Aloysius T. C. AuYeung, Reg, No. 
35,432; William Thomas Babbitt, Reg, No. 39.591; Carol F. Barry, Reg. No. 41,600; Jordan Michael 
Becker, Reg. No. 39,602; Bradley J. Bereznak, Reg. No. 33,474; Michael A, Bernadicou, Reg. No. 35,934; 
Roger W. Blakety, Jr. a Reg. No. 25,831; Gregory D. Caldwell, Reg. No. 39,926; Ronald C. Card, Reg. No. 
44,587; Andrew C, Chen, Reg. No. 43,544; Thomas M. Coester, Reg. No. 39,637; Alin Corie, Reg. No. 
P46,244; Dennis WL deGuzman, Reg. No. 41,702; Stephen WL De Kierk, under 37 C.F.R. § 10.9(b); 
Michael Anthony DeSanctis, Reg. No. 39,957; Daniel M. De Vos, Reg. No. 37,813; Robert Andrew Diehl, 
Reg. No. 40,992; Sanjeet Dutta r Reg. No. P46.145; Matthew C, Fagan, Reg. No. 37,542; Tarek N- Fahmi, 
Reg. No. 41 ( 402; Paramita Ghosh, Reg. No. 42,806; James Y. Go, Reg. No. 40,621; James A. Henry, 
Reg. No. 41,064; Willmore F. Hotbrow III, Reg T No. P41,845; Sheryl Sue Holloway, Reg. No. 37,850; 
George W Hoover II, Reg. No, 32,992; Eric S. Hyman, Reg. No. 30,1 39; William W, Kidd, Reg, No. 
31,772; Sang Hui Kim, Reg. No. 40,450; Eric T. King, Reg. No. 44,188; Erica W. Kuo, Reg. No. 42,775; 
Kurt P. Leyendecker, Reg. No. 42,799; Michael J. Mallie, Reg. No. 36,591; Andre L Marais, under 37 
C.F.R T § 10.9(b); Paul A. Mendonsa, Reg. No. 42,879; Darren J. Miliiken, Reg. 42,004; Lisa A, Norris, 
Reg. No. 44,976; Chun M. Ng r Reg. No. 36,378; Thien T. Nguyen, Reg. No. 43,835; Thinh V. Nguyen, 
O Reg. No. 42,034; Dennis A. Nicholls, Reg, No. 42,036; Daniel E. Ovanezian, Reg, No. 41,236; Marina 
S Portnova, Reg. No. P45,750; Babak Redjaian, Reg. No, 42,096; William F. Ryann, Reg. 44,313; James 
■m H. Salter, Reg. No. 35,668; William W. Schaal, Reg. No. 39,018; James C. Scheller, Reg. No. 31 ,195; 
lh Jeffrey Sam Smith, Reg. No. 39,377; Maria McCormack Sobrino, Reg. No. 31,639; Stanley W. Sokoloff, 
g Reg. No. 25,128; Judith A. Szepesi, Reg. No. 39,393; Vincent P. Tassinari, Reg. No. 42,179; Edwin H. 
%l Taylor, Reg, No. 25,129; John F. Travis, Reg. No, 43,203; George G. C. Tseng, Reg. No. 41,355; Joseph 

A. Twarowski, Reg. No. 42,191; Lester J. Vincent, Reg. No. 31,460; Glenn E. Von Tersch, Reg. No. 
f : 41 ,364; John Patrick Ward, Reg. No. 40,216; Mark L. Watson, Reg. No. P46.322; Thomas C. Webster, 
% i Reg. No, P46,154; Charles T J, Weigeli, Reg. No. 43,398; Kirk D. Williams, Reg. No, 42,229; James M. 
$ Wu, Reg. No, 45,241; Steven D. Yates, Reg. No, 42,242; and Norman Zafman, Reg, No. 26,250; my 

f] patent attorneys, and Justin M. Dillon, Reg. No. 42,486; my patent agent, of BLAKELY, SOKDLOFF, 
m TAYLOR & ZAFMAN LLP, with offices located at 1 2400 Wilshire Boulevard, 7th Floor, Los Angeles, 
y California 90025, telephone (310) 207-3800, and Alan K. Aldous, Reg. No. 31,905; Robert D. Anderson, 
£ Reg. No. 33,826; Joseph R. Bond, Reg. No. 36,458; Richard C. Caiderwood, Reg. No. 35,468; Jeffrey S. 
|f Draeger, Reg, No. 41 ,000; Cynthia Thomas Faatz, Reg No. 39,973; Sean Fitzgerald, Reg. No, 32,027; 
W John N; Greaves, Reg. No. 40,362; Seth Z, Kalson, Reg. No. 40,670; David J. Kaplan, Reg. No, 41,105; 
IP Charles A. Mirho, Reg. No, 41,199; Leo V, Novakoski, Reg. No. 37,198; Naomi Obinata, Reg. No. 

39,320; Thomas C. Reynolds, Reg. No. 32,488; Kenneth M. Seddon, Reg. No. 43,105; Mark Seeley, Reg- 
No. 32,299; Steven P. Skabrat, Reg. No. 36,279; Howard A, Skaist, Reg, No. 36,008; Steven C. Stewart, 
Reg. No. 33,555; Raymond J. Werner, Reg, No. 34,752; Robert G. Winkle, Reg, No. 37,474; and Charles 
K. Young, Reg. No. 39,435; my patent attorneys, and Thomas Raleigh Lane, Reg, No. 42,781 ; Calvin E. 
Wells; Reg. No. P43,256 f Peter Lam, Reg. No. 44,855; and Gene I. Su, Reg. No. 45,140; my patent 
agents, of INTEL CORPORATION; and James R. Thein, Reg. No, 31,710, my patent attorney; with full 
power of substitution and revocation, to prosecute this application and to transact ail business in the 
Patent and Trademark Office connected herewith. 
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APPENDIX B 

Title 37, Code of Federal Regulation, Section 1 .56 
Duty to Disclose Information Material to Patentability 

(a) A patent by its very nature Is affected with a public interest. The public interest is best served, 
and the most effective patent examination occurs when, at the time an application is being examined, the 
Off ice Is aware of and evaluates the teachings of all information material to patentability. Each individual 
associated with the filing and prosecution of a patent application has a duty of candor and good faith in 
dealing with the Office, which includes a duly to disclose to the Office all information known to that individual 
to be material to patentability as defined in this section. The duty to disclosure information exists with respect 
to each pending claim until the claim is cancelled or withdrawn from consideration, or the application becomes 
abandoned. Information material to the patentability of a claim that is cancelled or withdrawn from 
consideration need not be submitted if the information is not material to the patentability of any ciaim 
remaining under consideration in the application. There is no duty to submit information which is not material 
to the patentability of any existing claim. The duty to disclosure all information known to be material to 
patentability is deemed to be satisfied if all information known to be material to patentability of any claim 
issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by §§1 .97(b)-(d) 
and 1 ,98. However, no patent will be granted on an application in connection with which fraud on the Office 
was practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. 
The Office encourages applicants to carefully examine: 

(1 ) Prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2} The closest information over which individuals associated with the ftiing or prosecution of a 
patent application believe any pending claim patentably defines, to make sure that any material information 
contained therein is disclosed to the Office. 

(b) Under this section, information is material to patentability when it is not cumulative to 
information already of record or being made or record in the application, and 

(1 ) It establishes, by *rt$elf or in combination with other information, a prima facie case of 
unpatentability of a claim; or 

(2) it refutes, or is inconsistent with, a position the applicant takes in: 

(1) Opposing an argument of unpatentability relied on by the Office, or 

(ii) Asserting an argument of patentability. 

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is 
unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term In the claim 
its broadest reasonable construction consistent with the specification, and before any consideration is given to 
evidence which may be submitted in an attempt to establish a contrary conclusion of patentability. 

(c) individuals associated with the filing or prosecution of a patent application within the 
meaning of this section are: 

(1 } Each inventor named in the application; 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the 
application and who is associated with the inventor, with the assignee or with anyone to whom there is an 
obligation to assign the application. 

(d) Individuals other than the attorney, agent or inventor may comply with this section fay 
disclosing information to the attorney, agent, or inventor. 
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